<template>
	<view class="product">
		<!--顶部商品轮播图-->
		<view class="carousel">
			<swiper indicator-dots circular=true duration="400">
				<swiper-item class="swiper-item" v-for="(item,index) in productDetail.covers" :key="index">
					<view class="image-wrapper">
						<image :src="item" class="loaded" mode="aspectFill"></image>
					</view>
				</swiper-item>
			</swiper>
		</view>
		<!--商品信息-->
		<view class="introduce-section">
			<text class="title">{{ productDetail.name || (' 暂无商品详情' + (!!errorInfo ? '[' + errorInfo + ']' : '')) }}</text>
			<text class="sketch">{{ productDetail.sketch }}</text>
			<view class="price-box point-box" v-if="productDetail.point_exchange_type == 4">
				该商品仅需 <text class="price">{{ productDetail.point_exchange }} 积分</text>
			</view>
			<view class="price-box" v-else>
				<text class="price-tip" v-if="vipgd==1">兑换积分</text>
				<text class="price" v-if="vipgd==1">{{productDetail.product_mdl }}</text>
				<text class="price-tip" v-if="vipgd==0">¥</text>
				<text class="price" v-if="vipgd==0">{{ currentSkuPrice || productDetail.price }}</text>
				<text class="m-price" v-if="parseFloat(productDetail.market_price) > parseFloat(productDetail.price)&&vipgd==0">{{ productDetail.market_price }}</text>
				<text class="coupon-tip" v-if="parseFloat(productDetail.market_price) > parseFloat(productDetail.price)&&vipgd==0">{{ ((currentSkuPrice || productDetail.price) / productDetail.market_price) | discountFilter }}折</text>
			</view>
			<view class="bot-row">
				<text>销量: {{ productDetail.sales || 0 }}</text>
				<text>收藏量: {{ productDetail.collect_num || 0 }}</text>
				<text>浏览量: {{ productDetail.view || 0 }}</text>
			</view>
			<view class="bot-row">
				<text>评分: {{ productDetail.match_point || 0 }}</text>
				<text>评价量: {{ productDetail.comment_num || 0 }}</text>
				<text>分享量: {{ productDetail.transmit_num || 0 }}</text>
			</view>
		</view>
		<!--  分享 -->
		<view class="share-section" v-if="false">
			<view class="share-icon">
				<text class="iconfont iconxingxing"></text>
				返
			</view>
			<text open-type="contact" class="tit">分享该商品给你的朋友们</text>
			<i class="iconfont iconbangzhu1"></i>

			<!--#ifndef H5-->
			<button :disabled="!!productDetail" class="share-btn" open-type="share">
				立即分享
				<i class="iconfont iconyou"></i>
			</button>
			<!--#endif-->

			<!--#ifdef H5-->
			<button :disabled="!!productDetail" class="share-btn" @tap.stop="shareToH5">
				立即分享
				<i class="iconfont iconyou"></i>
			</button>
			<!--#endif-->
		</view>

		<!--发货地址-->
		<view class="c-list">
			<!--库存-->
			<view class="c-row b-b" v-if="productDetail.stock && productDetail.is_stock_visible == 1">
				<text class="tit">商品库存</text>
				<view class="con-list" v-if="productDetail.stock > 0">
					{{ currentStock || productDetail.stock }} 个
				</view>
				<view class="con-list red" v-else>
					库存不足
				</view>
			</view>
			<!--发货地址-->
			<view class="c-row b-b" v-if="productDetail.address_name">
				<text class="tit">发货地址</text>
				<view class="con-list">
					{{ productDetail.address_name }}
				</view>
			</view>
			<!--购买类型-->
			<view class="c-row b-b" @tap="toggleSpec">
				<text class="tit">购买类型</text>
				<view class="con">
					<text class="selected-text" v-for="(sItem, sIndex) in specSelected" :key="sIndex">
						{{sItem.title}}
					</text>
					<text v-if="specSelected.length > 0"> * {{ cartCount }}</text>
					<text class="selected-text" v-if="productDetail.base_attribute_format && productDetail.base_attribute_format.length === 0">
						<!--{{ productDetail.name }} * 1-->
						基础款 * {{ cartCount }}
					</text>
					<text class="selected-text" v-if="specSelected.length === 0">暂无购买类型</text>
				</view>
				<i class="iconfont iconyou" v-if="!productDetail"></i>
			</view>
			<view class="c-row b-b" v-if="false">
				<text class="tit">优惠券</text>
				<text class="con t-r red" @tap="toggleMask('show')">领取优惠券</text>
				<i class="iconfont iconyou" v-if="!productDetail"></i>
			</view>
			<view class="c-row b-b" v-if="vipgd==0">
				<text class="tit">赠送贡献值</text>
				<text class="con t-r">{{productDetail.give_mdl}}</text>
			</view>
			<view class="c-row b-b" v-if="false">
				<text class="tit">限购说明</text>
				<view class="con-list">
					<text v-if="productDetail.point_exchange_type">{{ productDetail.max_buy | maxBuyFilter }}</text>
					<text v-else>暂无限购说明</text>
				</view>
			</view>
			<view class="c-row b-b" v-if="false">
				<text class="tit">积分活动</text>
				<view class="con-list" v-if="productDetail.point_exchange_type">
					<text v-if="productDetail.point_exchange_type">积分兑换类型: {{ productDetail.point_exchange_type | pointExchangeTypeFilter }}
					</text>
					<text>积分赠送类型: {{ productDetail.integral_give_type | integralGiveTypeFilter }} </text>
					<text>最少可获得: {{ productDetail | givePointFilter }} </text>
					<text v-if="productDetail.point_exchange != 0">兑换所需积分: {{ productDetail.point_exchange }} </text>
					<text v-if="productDetail.max_use_point != 0">最大可使用积分: {{ productDetail.max_use_point }} </text>
					<text class="buy-now" @tap="addCart('buy')" v-if="productDetail.point_exchange_type == 3">积分兑换 >> </text>
				</view>
				<view class="con-list" v-else>
					暂无积分活动
				</view>
			</view>
			<view class="c-row b-b" @tap="showService">
				<text class="tit">服务</text>
				<view class="con-list" v-if="productDetail.tags && productDetail.tags.length >= 1">
					<text>{{ productDetail.tags[0] }}... </text>
				</view>
				<view class="con-list" v-else>
					暂无服务
				</view>
				<i class="iconfont iconyou" v-if="productDetail.tags && productDetail.tags.length >= 1"></i>
			</view>
			<!-- <view class="c-row b-b" @tap="showLadderPreferential">
					<text class="tit">阶梯优惠</text>
					<view class="con-list" v-if="productDetail.ladderPreferential && productDetail.ladderPreferential.length > 0">
						<text v-for="(item, index) in productDetail.ladderPreferential" :key="index">
							满{{ item.quantity }}件
								<text v-if="parseInt(item.type, 10) === 1">每件减{{ item.price }}元</text>
								<text v-if="parseInt(item.type, 10) === 2">每件{{ parseInt(item.price, 10) }}折</text>
						</text>
					</view>
					<view class="con-list" v-else>
						暂无阶梯优惠
					</view>
					<i class="iconfont iconyou" v-if="productDetail.ladderPreferential && productDetail.ladderPreferential.length >= 1"></i>
				</view> -->
			<!--			<view class="c-row b-b" v-if="productDetail.attributeValue" @tap="showAttributeValue">-->
			<!--				<text class="tit">参数</text>-->
			<!--				<view class="con-list" v-if="productDetail.attributeValue && productDetail.attributeValue.length >= 1">-->
			<!--					<text>-->
			<!--						{{ `${productDetail.attributeValue && productDetail.attributeValue[0].title}: ${productDetail.attributeValue && productDetail.attributeValue[0].value}` }}-->
			<!--						...-->
			<!--					</text>-->
			<!--				</view>-->
			<!--				<view class="con-list" v-else>-->
			<!--					暂无商品基本信息-->
			<!--				</view>-->
			<!--				<i class="iconfont iconyou" v-if="productDetail.attributeValue && productDetail.attributeValue.length >= 1"></i>-->
			<!--			</view>-->
		</view>
		<!-- 商品详情广告 -->
		<!-- 测试 adpid="1111111111"-->
		<view class="ad-view">
			<ad adpid="1948736446" @load="adLoad"></ad>
		</view>
		<!-- 评价 -->
		<view class="eva-section" @tap="toEvaluateList">
			<view class="e-header">
				<text class="tit">评价</text>
				<text>({{ productDetail.comment_num || 0 }})</text>
				<text class="tip" v-if="productDetail.match_ratio">好评率 {{ productDetail.match_ratio }}%</text>
				<text class="tip" v-else>暂无评价信息</text>
				<i class="iconfont iconyou"></i>
			</view>
			<!--again_addtime: "0"-->
			<!--again_content: ""-->
			<!--again_covers: []-->
			<!--again_explain: ""-->
			<!--content: "我的觉得ok！"-->
			<!--covers: ["blob:http://192.168.20.45:9527/b4abfa1c-7387-436c-883d-5d0fabb650ff",…]-->
			<!--created_at: "1574912184"-->
			<!--explain_first: ""-->
			<!--explain_type: "2"-->
			<!--is_anonymous: "0"-->
			<!--member_head_portrait: null-->
			<!--member_id: "2"-->
			<!--member_nickname: "stavyan"-->
			<!--product_id: "43"-->
			<!--scores: "3"-->
			<view class="eva-box" v-if="productDetail.evaluate && productDetail.evaluate.length > 0">
				<image class="portrait" :src="productDetail.evaluate && productDetail.evaluate[0] && productDetail.evaluate[0].member_head_portrait || '/static/missing-face.png'"
				 mode="aspectFill"></image>
				<view class="right">
					<view class="name">
						<text>
							{{ productDetail.evaluate && productDetail.evaluate[0] && productDetail.evaluate[0].member_nickname || '匿名用户' }}
						</text>
						<rf-rate v-if="evaluateList.length > 0" size="16" disabled="true" :value="evaluateList[0].scores" active-color="#fc9f56" />
					</view>
					<text class="con in2line">{{ productDetail.evaluate && productDetail.evaluate[0] && productDetail.evaluate[0].content || '这个人很懒，什么都没留下~' }}</text>
					<view class="bot">
						<text class="attr">购买类型：{{ productDetail.evaluate && productDetail.evaluate[0] && productDetail.evaluate[0].sku_name || '基础版' }}</text>
						<text class="time">{{ productDetail.evaluate && productDetail.evaluate[0] && productDetail.evaluate[0].created_at | time }}</text>
					</view>
				</view>
			</view>
		</view>

		<!-- 店铺 -->
		<view class="eva-section" v-if="productDetail.merchant " @tap="toMerchant(productDetail.merchant.id)">
			<view class="e-header" style="height: auto;position: relative;">
				<image :src="productDetail.merchant.cover||''" mode="" class="company-logo"></image>
				<text class="company-name" style="top: 4upx;">{{ productDetail.merchant.title }}</text>
				<text class="company-name">{{ productDetail.merchant.address_name }}</text>
				<!--				<text class="go-company" @click.stop="messageDetail(productDetail.merchant.id)">联系客服</text>-->
			</view>

			<!-- <view class="introduce-section" style="padding: 21upx 0 0 0;text-align: center;">
				<view class="bot-row" style="font-size: 28upx;">
					<text>宝贝描述: 4.8</text>
					<text>卖家服务: 5.0</text>
					<text>物流服务: 4.9</text>
				</view>
			</view> -->

		</view>

		<!--底部商品详情-->
		<view class="detail-desc">
			<view class="d-header">
				<text>商品详情</text>
			</view>
			<rich-text :nodes="productDetail.intro | formatRichText"></rich-text>
		</view>

		<!-- 底部操作菜单 -->
		<view class="page-bottom">
			<navigator url="/pages/index/index" open-type="switchTab" class="p-b-btn">
				<i class="iconfont iconxiatubiao--copy"></i>
				<text>首页</text>
			</navigator>
			<navigator url="/pages/cart/cart" open-type="switchTab" class="p-b-btn cart">
				<i class="iconfont icongouwuche"></i>
				<text>购物车</text>
				<rf-badge v-if="token && cartNum && cartNum > 0" type="error" size="small" class="badge" :text="cartNum"></rf-badge>
			</navigator>
			<view class="p-b-btn" :class="{active: favorite}" @tap="toFavorite">
				<i class="iconfont iconshoucang"></i>
				<text>收藏</text>
			</view>
			<!--<view @tap="navTo(`/pages/product/service/index`)" class="p-b-btn">-->
			<!--<i class="iconfont icondanseshixintubiao-"></i>-->
			<!--<text>客服</text>-->
			<!--</view>-->
			<view class="action-btn-group">
				<button type="primary" :disabled="addCartBtnDisabled" class=" action-btn no-border add-cart-btn" @tap="addCart('cart')">加入购物车</button>
				<button type="primary" class="action-btn no-border buy-now-btn" :disabled="buyBtnDisabled" @tap="addCart('buy')">立即购买</button>
			</view>
		</view>

		<!-- 服务-模态层弹窗 -->
		<view class="popup service" :class="serviceClass" @tap="hideService">
			<!-- 遮罩层 -->
			<view class="mask"></view>
			<view class="layer layer-service">
				<view class="content">
					<view class="row" v-for="(item,index) in productDetail.tags" :key="index">
						<view class="title">{{item}}</view>
						<view class="description">此商品承诺{{item}}</view>
					</view>
				</view>
				<button class="btn" @tap="hideService">完成</button>
			</view>
		</view>

		<!-- 阶梯优惠-模态层弹窗 -->
		<view class="popup service" :class="ladderPreferentialClass" @tap="hideService">
			<!-- 遮罩层 -->
			<view class="mask"></view>
			<view class="layer layer-service">
				<view class="content">
					<view class="row" v-for="(item,index) in productDetail.ladderPreferential" :key="index">
						<view class="title">满{{ item.quantity }}件 <text v-if="parseInt(item.type, 10) === 1">每件减{{ item.price }}元</text>
							<text v-if="parseInt(item.type, 10) === 2">每件{{ parseInt(item.price, 10) }}折</text>
						</view>
					</view>
				</view>
				<button class="btn" @tap="hideService">完成</button>
			</view>
		</view>

		<!-- 参数-模态层弹窗 -->
		<view class="popup service" :class="attributeValueClass" @tap="hideService">
			<!-- 遮罩层 -->
			<view class="mask"></view>
			<view class="layer layer-service">
				<view class="content">
					<view class="row" v-for="(item,index) in productDetail.attributeValue" :key="index">
						<view class="title">
							{{ `${item.title}: ${item.value}` }}
						</view>
					</view>
				</view>
				<button class="btn" @tap="hideService">完成</button>
			</view>
		</view>

		<!-- 规格-模态层弹窗 -->
		<view class="popup spec" :class="specClass" @touchmove.stop.prevent="stopPrevent" @tap="toggleSpec">
			<!-- 遮罩层 -->
			<view class="mask" @tap="hideSpec"></view>
			<view class="layer attr-content" @tap.stop="stopPrevent">
				<view class="a-t">
					<image :src="showTypeImage || productDetail.picture"></image>
					<view class="right">
						<text class="title">{{ productDetail.name }}</text>
						<text class="price" v-if="vipgd==0">¥{{ currentSkuPrice || productDetail.minSkuPrice }}</text>
						<text class="price" v-if="vipgd==1">兑换积分{{ productDetail.product_mdl }}</text>
						<text class="stock">库存：{{ currentStock || productDetail.stock }}件</text>
						<view class="selected" v-if="specSelected.length > 0">
							已选：
							<text class="selected-text" v-for="(sItem, sIndex) in specSelected" :key="sIndex">
								{{sItem.title}}
							</text>
							<text v-if="specSelected.length > 0">
								* {{ cartCount }}
							</text>
						</view>
					</view>
				</view>
				<view v-for="(item,index) in specList" :key="index" class="attr-list">
					<text>{{item.title}}</text>
					<view class="item-list">
						<view class="tit" v-for="(childItem, childIndex) in specChildList" v-if="childItem.base_spec_id === item.base_spec_id"
						 :key="childIndex" :class="{selected: childItem.selected}" :style="childItem.selected && parseInt(item.show_type) === 2 ? styleObject: ''"
						 @tap="selectSpec(childIndex, childItem.base_spec_id, item.show_type)">
							<text v-if="parseInt(item.show_type) === 1">
								{{childItem.title }}
							</text>
							<text v-if="parseInt(item.show_type) === 2">
								{{childItem.title }}
							</text>
							<view v-if="parseInt(item.show_type) === 3">
								<image class="img" :src="childItem.data || productDetail.picture" mode="aspectFill"></image>
								{{childItem.title }}
							</view>
						</view>
					</view>
				</view>
				<view class="select-count">
					<text>购买数量</text>
					<rf-number-box class="step" :min="1" :max="parseInt(currentStock || productDetail.stock, 10)" :value="cartCount"
					 @eventChange="numberChange"></rf-number-box>
				</view>
				<button class="btn" @tap="toggleSpec">完成</button>
			</view>
		</view>
		<!--&lt;!&ndash; 分享 &ndash;&gt;-->
		<!--<share-->
		<!--ref="share"-->
		<!--:contentHeight="580"-->
		<!--:shareList="shareList"-->
		<!--&gt;</share>-->
		<!-- 优惠券面板 -->
		<view class="mask" :class="maskState===0 ? 'none' : maskState===1 ? 'show' : ''" @tap="toggleMask">
			<view class="mask-content" @tap.stop.prevent="stopPrevent">
				<!-- 优惠券页面，仿mt -->
				<view class="coupon-item" v-for="(item,index) in productDetail.canReceiveCoupon" :key="index" @tap="getCoupon(item)">
					<view class="con">
						<view class="left">
							<text class="title">{{item.title}}</text>
							<text class="time" v-if="parseInt(item.term_of_validity_type, 10) === 0">{{ item.start_time | time }} ~ {{ item.end_time | time }}</text>
							<text class="time" v-else>自领取之日 {{ item.fixed_term }}天内有效</text>
						</view>
						<view class="right">
							<text class="price" v-if="item.money">{{item.money }}</text>
							<text class="price-discount" v-else>{{ `${item.discount}折` }}</text>
							<text>满{{ item.at_least }}可用</text>
						</view>
						<view class="circle l"></view>
						<view class="circle r"></view>
					</view>
					<view class="tips">
						<text v-if="item.range_type">
							{{ parseInt(item.range_type, 10) === 2 ? '部分产品使用' : '全场产品使用' }}
						</text>
					</view>
				</view>
			</view>
		</view>
		<!--页面加载动画-->
		<rf-loading v-if="loading"></rf-loading>
		<!--直播窗口-->

		<view class="video-box" v-if="is_live == '1'" @click="goZhibo(productDetail.merchant.id)">
			<image src="../../static/zhibo-bg.png" class="zhibo-bg" mode=""></image>
			<image src="../../static/zhibo-name.png" class="zhibo-name" mode=""></image>
		</view>
	</view>
</template>

<script>
	/**
	 * @des 商品详情
	 *
	 * @author stav stavyan@qq.com
	 * @date 2020-03-23 15:04
	 * @copyright 2019
	 */
	import {
		cartItemCount,
		cartItemCreate,
		orderPreview,
		getAdReward,
		productDetail
	} from "@/api/product";
	import rfNumberBox from '@/components/rf-number-box';
	import {
		collectCreate,
		collectDel,
		transmitCreate
	} from "@/api/basic";
	import moment from '@/utils/moment';
	import {
		couponReceive
	} from "@/api/userInfo";

	import rfRate from "@/components/rf-rate/rf-rate";
	import rfBadge from '@/components/rf-badge/rf-badge'
	export default {
		components: {
			rfBadge,
			rfRate,
			rfNumberBox,
		},
		filters: {
			/**
			 * 处理富文本里的图片宽度自适应
			 * 1.去掉img标签里的style、width、height属性
			 * 2.img标签添加style属性：max-width:100%;height:auto
			 * 3.修改所有style里的width属性为max-width:100%
			 * 4.去掉<br/>标签
			 * @param html
			 * @returns {void|string|*}
			 */
			formatRichText(html) { //控制小程序中图片大小
				if (html) {
					let newContent = html.replace(/<img[^>]*>/gi, function(match, capture) {
						match = match.replace(/style="[^"]+"/gi, '').replace(/style='[^']+'/gi, '');
						match = match.replace(/width="[^"]+"/gi, '').replace(/width='[^']+'/gi, '');
						match = match.replace(/height="[^"]+"/gi, '').replace(/height='[^']+'/gi, '');
						return match;
					});
					newContent = newContent.replace(/style="[^"]+"/gi, function(match, capture) {
						match = match.replace(/width:[^;]+;/gi, 'max-width:100%;').replace(/width:[^;]+;/gi, 'max-width:100%;');
						return match;
					});
					newContent = newContent.replace(/<br[^>]*\/>/gi, '');
					newContent = newContent.replace(/\<img/gi,
						'<img style="max-width:100%;height:auto;display:inline-block;margin:10rpx auto;"');
					return newContent;
				} else {
					return '暂无商品详情'
				}
			},
			time(val) {
				return moment(val * 1000).format('YYYY-MM-DD HH:mm')
			},
			discountFilter(val) {
				return (val * 10).toFixed(2);
			},
			maxBuyFilter(val) {
				return parseInt(val, 10) === 0 ? '不限购' : `限购：${val}`;
			},
			pointExchangeTypeFilter(val) {
				const type = ['', '非积分兑换', '积分加现金', '积分兑换或直接购买', '只支持积分兑换'];
				return type[parseInt(val, 10)];
			},
			integralGiveTypeFilter(val) {
				const type = ['固定积分', '百分比'];
				return type[parseInt(val, 10)];
			},
			givePointFilter(val) {
				return parseInt(val.integral_give_type, 10) === 1 ?
					`${Math.round(parseInt(val.give_point, 10) / 100 * parseInt(val.minSkuPrice, 10))} 积分` :
					parseInt(val.integral_give_type, 10);
			}
		},
		data() {
			return {
				showVideo: true,
				isPlay: false,
				serviceClass: 'none', //服务弹窗css类，控制开关动画
				ladderPreferentialClass: 'none', //服务弹窗css类，控制开关动画
				attributeValueClass: 'none', //服务弹窗css类，控制开关动画
				cartType: null,
				maskState: 0, //优惠券面板显示状态
				couponList: [],
				productDetail: {},
				styleObject: {},
				showTypeImage: null,
				specClass: 'none',
				specSelected: [],
				favorite: false,
				shareList: [],
				currentStock: null,
				currentSkuPrice: null,
				specList: [],
				specChildList: [],
				cartCount: 1,
				product_id: null,
				evaluateList: [],
				token: null,
				cartNum: null,
				loading: true,
				errorInfo: '',
				videoContext: '',
				is_live: '0',
				vipgd: "0"
			};
		},
		computed: {
			buyBtnDisabled() {
				return (this.currentStock || this.productDetail.stock) == 0;
			},
			addCartBtnDisabled() {
				return this.productDetail.point_exchange_type == 2 ||
					this.productDetail.point_exchange_type == 4 ||
					(this.currentStock || this.productDetail.stock) == 0 ||
					this.productDetail.is_virtual == 1;
			}

		},
		async onLoad(options) {
			if (options.vipgd) {
				this.vipgd = 1
				console.log(this.vipgd)
			}
			this.initData(options.id);
			//规格 默认选中第一条
			this.specList.forEach(item => {
				for (let cItem of this.specChildList) {
					if (cItem.pid === item.id) {
						this.$set(cItem, 'selected', true);
						this.specSelected.push(cItem);
						break; //forEach不能使用break
					}
				}
			});
			this.product_id = options.id;
		},
		onShareAppMessage(res) {
			// #ifdef MP-WEIXIN
			this.$post(`${transmitCreate}`, {
				topic_type: 'product',
				topic_id: this.product_id,
			}).then(() => {
				return {
					title: this.productDetail.name,
					path: '/pages/product/product?id=' + this.product_id
				}
			})
			// #endif
			// #ifdef MP-QQ
			return {
				title: this.productDetail.name,
				path: '/pages/product/product?id=' + this.product_id
			}
			// #endif
		},
		methods: {
			adLoad(e) {
				if(uni.getStorageSync('accessToken')){
					this.adhttp("ad_cart","1948736446")
				}
				// console.log(e)
				// this.token = uni.getStorageSync('accessToken') || undefined;
				// if (this.token) {
				// 	this.$post(`${getAdReward}`, {
				// 		ad_type: 'ad_product',
				// 		ad_id: e.target.id,
				// 		ad_open_id: '1948736446'
				// 	}).then(r => {
				// 		console.log(r)

				// 	}).catch((err) => {
				// 		console.log(err)
				// 	});
				// }

			},
			getCurPage() {
				let pages = getCurrentPages();
				let curPage = pages[pages.length - 1];
				return curPage
			},
			play() {
				this.isPlay = true;
			},
			navTo(url) {
				if (!this.token) {
					uni.showModal({
						content: '会话已过期，是否跳转登录页面？',
						success: (confirmRes) => {
							if (confirmRes.confirm) {
								uni.navigateTo({
									url: '/pages/public/login'
								});
							}
						}
					});
				} else {
					uni.navigateTo({
						url
					});
				}
			},
			messageDetail(id) {
				uni.navigateTo({
					url: `/pages/message/messageDetail?id=` + id
				})
			},
			//服务弹窗
			showService() {
				if (this.productDetail.tags && this.productDetail.tags.length === 0) return;
				this.serviceClass = 'show';
			},
			showLadderPreferential() {
				if (this.productDetail.ladderPreferential.length === 0) return;
				this.ladderPreferentialClass = 'show';
			},
			showAttributeValue() {
				if (this.productDetail.attributeValue.length === 0) return;
				this.attributeValueClass = 'show';
			},
			shareToH5() {
				this.$api.msg('请复制连接进行分享');
			},
			//关闭服务弹窗
			hideService() {
				this.serviceClass = 'hide';
				this.ladderPreferentialClass = 'hide';
				this.attributeValueClass = 'hide';
				setTimeout(() => {
					this.serviceClass = 'none';
					this.ladderPreferentialClass = 'none';
					this.attributeValueClass = 'none';
				}, 200);
			},
			/**
			 *@des 获取优惠券
			 *@author stav stavyan@qq.com
			 *@blog https://stavtop.club
			 *@date 2019/12/12 15:17:34
			 *@param arguments
			 */
			async getCoupon(item) {
				if (!this.token) {
					this.maskState = 0;
					uni.showModal({
						content: '会话已过期，是否跳转登录页面？',
						success: (confirmRes) => {
							if (confirmRes.confirm) {
								uni.clearStorage();
								uni.navigateTo({
									url: '/pages/public/login'
								});
							}
						}
					});
					return;
				}
				await this.$post(`${couponReceive}`, {
					id: item.id
				}).then(() => {
					this.$api.msg('领取成功');
					this.maskState = 0;
				}).catch(err => {
					this.maskState = 0;
					console.log(err);
				})
			},
			/**
			 *@des 跳转至评价列表
			 *@author stav stavyan@qq.com
			 *@blog https://stavtop.club
			 *@date 2019/11/28 15:32:26
			 *@param arguments
			 */
			toEvaluateList() {
				uni.navigateTo({
					url: `/pages/order/evaluation/list?comment_num=${this.productDetail.comment_num}&evaluateStat=${JSON.stringify(this.productDetail.evaluateStat)}`
				})
			},
			goZhibo(id) {
				uni.navigateTo({
					url: `/pages/liveBroadcast/liveBroadcast?id=` + id
				})
			},
			toMerchant(id) {
				uni.navigateTo({
					url: `/pages/merchant/merchant?id=` + id
				})
			},
			numberChange(data) {
				this.cartCount = data.number;
			},
			//显示优惠券面板
			toggleMask(type) {
				if (!this.productDetail.id) return;
				let timer = type === 'show' ? 10 : 300;
				let state = type === 'show' ? 1 : 0;
				this.maskState = 2;
				setTimeout(() => {
					this.maskState = state;
				}, timer)
			},
			/**
			 *@des 初始化数据
			 *@author stav stavyan@qq.com
			 *@blog https://stavtop.club
			 *@date 2019/11/18 15:48:21
			 */
			async initData(id) {
				this.token = uni.getStorageSync('accessToken');
				this.cartNum = uni.getStorageSync('cartNum');
				await this.getProductDetail(id);
			},
			// 获取产品详情
			async getProductDetail(id) {
				await this.$get(`${productDetail}`, {
					id,
				}).then(async r => {
					this.loading = false;
					this.productDetail = r.data;
					this.is_live = r.data.merchant.is_live;
					this.evaluateList = await r.data.evaluate;
					this.favorite = this.productDetail.myCollect ? true : false;
					this.specList = this.productDetail.base_attribute_format
					this.specList.forEach(item => {
						this.specChildList = [...this.specChildList, ...item.value]
					});
					/**
					 * 修复选择规格存储错误
					 * 将这几行代码替换即可
					 * 选择的规格存放在specSelected中
					 */
					this.specSelected = [];
					r.data.base_attribute_format.forEach(item => {
						item.value[0].selected = true
						this.specSelected.push(item.value[0]);
					});
					let skuStr = [];
					this.specSelected.forEach(item => {
						skuStr.push(item.base_spec_value_id)
					})
					this.productDetail.sku.forEach(item => {
						if (item.data === skuStr.join('-')) {
							this.currentStock = item.stock;
							this.currentSkuPrice = item.price;
							return;
						}
					})
				}).catch(err => {
					this.loading = false;
					this.errorInfo = err;
				})
			},
			//规格弹窗开关
			toggleSpec() {
				if (!this.productDetail.id) return;
				if (this.specClass === 'show') {
					if (!this.token) {
						this.specClass = 'none';
						uni.showModal({
							content: '会话已过期，是否跳转登录页面？',
							success: (confirmRes) => {
								if (confirmRes.confirm) {
									uni.clearStorage();
									let routes = getCurrentPages(); // 获取当前打开过的页面路由数组
									let curRoute = routes[routes.length - 1].route //获取当前页面路由
									let curParam = routes[routes.length - 1].options; //获取路由参数
									let param = '',
										i = 0;
									for (let key in curParam) {
										if (i == 0) {
											param += '?' + key + '=' + curParam[key];
										} else {
											param += '&' + key + '=' + curParam[key]
										}
										i++
									}

									uni.navigateTo({
										url: '/pages/public/login?callbackUrl=/' + curRoute + param
									});
								}
							}
						});
						return;
					}
					if (this.specSelected.length < this.productDetail.base_attribute_format.length) {
						this.$api.msg('请先选择规格');
						return;
					}
					if (this.cartType === 'cart') {
						this.cartType = null;
						if (this.currentStock == 0) {
							this.$api.msg('库存不足');
							return;
						}
						this.handleCartItemCreate();
					} else if (this.cartType === 'buy') {
						this.cartType = null;
						if (this.currentStock == 0) {
							this.$api.msg('库存不足');
							return;
						}
						this.buy();
					}
					this.specClass = 'hide';
					setTimeout(() => {
						this.specClass = 'none';
					}, 250);
				} else if (this.specClass === 'none') {
					this.specClass = 'show';
				}
			},
			hideSpec() {
				this.specClass = 'hide';
				setTimeout(() => {
					this.specClass = 'none';
				}, 250);
			},
			// 添加商品至购物车
			async handleCartItemCreate() {
				// const type = parseInt(this.productDetail.point_exchange_type , 10)
				// if ( type === 2 || type === 4) {
				// 	uni.showToast({ title: "该商品不支持添加至购物车，请直接下单购买", icon: "none" });
				// 	return;
				// }
				let sku_id;
				let skuStr = null;
				if (this.productDetail.sku.length === 1) {
					sku_id = this.productDetail.sku[0].id
				} else {
					if (this.productDetail.base_attribute_format.length === 1) {
						if (this.specSelected.length < 1) {
							this.$api.msg('请先选择规格');
							return;
						} else {
							skuStr = `${this.specSelected[0].base_spec_value_id}`
						}
					} else if (this.productDetail.base_attribute_format.length === 2) {
						if (this.specSelected.length < 2) {
							this.$api.msg('请先选择规格');
							return;
						} else {
							skuStr = `${this.specSelected[0].base_spec_value_id}-${this.specSelected[1].base_spec_value_id}`
						}
					} else if (this.productDetail.base_attribute_format.length === 3) {
						if (this.specSelected.length < 3) {
							this.$api.msg('请先选择规格');
							return;
						} else {
							skuStr =
								`${this.specSelected[0].base_spec_value_id}-${this.specSelected[1].base_spec_value_id}-${this.specSelected[2].base_spec_value_id}`
						}
					}
					this.productDetail && this.productDetail.sku.forEach(item => {
						if (item.data === skuStr) {
							sku_id = item.id;
							return;
						}
					})
				}
				await this.$post(`${cartItemCreate}`, {
					sku_id,
					num: this.cartCount
				}).then(async r => {
					await this.$get(`${cartItemCount}`).then(r => {
						uni.setStorageSync('cartNum', r.data);
						this.cartNum = r.data;
					});
					this.$api.msg('添加成功，在购物车等');
				}).catch(err => {
					console.log(err)
				})
			},
			//选择规格
			selectSpec(index, pid, type) {
				let list = this.specChildList;
				list.forEach(item => {
					if (item.base_spec_id === pid) {
						this.$set(item, 'selected', false);
					}
				})
				if (parseInt(type, 10) === 3) {
					this.showTypeImage = list[index].data;
				}
				if (parseInt(type, 10) === 2) {
					this.styleObject = {
						color: list[index].data,
						// border: `1px solid ${list[index].data}`,
					};
				}
				this.$set(list[index], 'selected', true);
				//存储已选择
				/**
				 * 修复选择规格存储错误
				 * 将这几行代码替换即可
				 * 选择的规格存放在specSelected中
				 */
				this.specSelected = [];
				list.forEach(item => {
					if (item.selected === true) {
						this.specSelected.push(item);
					}
				})
				let skuStr = []
				this.specSelected.forEach(item => {
					skuStr.push(item.base_spec_value_id)
				})
				this.productDetail.sku.forEach(item => {
					if (item.data === skuStr.join('-')) {
						this.currentStock = item.stock;
						this.currentSkuPrice = item.price;
						return;
					}
				});
			},
			//分享
			share(res) {
				// this.$refs.share.toggleMask();
				if (res.from === 'button') { // 来自页面内分享按钮
					console.log(res.target)
				}
				return {
					title: '自定义分享标题',
					path: '/pages/test/test?id=123'
				}
			},
			/**
			 *@des 收藏
			 *@author stav stavyan@qq.com
			 *@blog https://stavtop.club
			 *@date 2019/11/21 17:00:45
			 */
			async toFavorite() {
				if (!this.productDetail.id) return;
				if (!this.token) {
					this.specClass = 'none';
					uni.showModal({
						content: '会话已过期，是否跳转登录页面？',
						success: (confirmRes) => {
							if (confirmRes.confirm) {
								uni.clearStorage();
								uni.navigateTo({
									url: '/pages/public/login'
								});
							}
						}
					});
				} else {
					this.favorite ? this.handleCollectDel() : this.handleCollectCreate();
				}
			},
			/**
			 *@des 收藏商品
			 *@author stav stavyan@qq.com
			 *@blog https://stavtop.club
			 *@date 2019/11/21 17:09:02
			 */
			async handleCollectCreate() {
				await this.$post(`${collectCreate}`, {
					topic_id: this.product_id,
					topic_type: 'product'
				}).then(r => {
					this.favorite = !this.favorite;
					this.$api.msg('收藏成功');
					this.getProductDetail(this.product_id);
				}).catch(err => {
					console.log(err)
				})
			},
			/**
			 *@des 取消收藏商品
			 *@author stav stavyan@qq.com
			 *@blog https://stavtop.club
			 *@date 2019/11/21 17:09:32
			 */
			async handleCollectDel() {
				await this.$del(`${collectDel}?id=${this.productDetail.myCollect.id}`).then(r => {
					this.favorite = !this.favorite;
					this.$api.msg('取消收藏成功');
					this.getProductDetail(this.product_id);
				}).catch(err => {
					console.log(err)
				})
			},
			async buy() {
				let sku_id;
				let skuStr;
				let sku_str;
				if (this.productDetail.sku.length === 1) {
					sku_id = this.productDetail.sku[0].id;
				} else {
					if (this.productDetail.base_attribute_format.length === 1) {
						if (this.specSelected.length < 1) {
							this.$api.msg('请先选择规格');
							return;
						} else {
							skuStr = `${this.specSelected[0].base_spec_value_id}`;
							sku_str = `${this.specSelected[0].title}`;
						}
					} else if (this.productDetail.base_attribute_format.length === 2) {
						if (this.specSelected.length < 2) {
							this.$api.msg('请先选择规格');
							return;
						} else {
							skuStr = `${this.specSelected[0].base_spec_value_id}-${this.specSelected[1].base_spec_value_id}`
							sku_str = `${this.specSelected[0].title} ${this.specSelected[1].title}`
						}
					} else if (this.productDetail.base_attribute_format.length === 3) {
						if (this.specSelected.length < 3) {
							this.$api.msg('请先选择规格');
							return;
						} else {
							skuStr =
								`${this.specSelected[0].base_spec_value_id}-${this.specSelected[1].base_spec_value_id}-${this.specSelected[2].base_spec_value_id}`
							sku_str = `${this.specSelected[0].title} ${this.specSelected[1].title} ${this.specSelected[2].title}`
						}
					}
					this.productDetail && this.productDetail.sku.forEach(item => {
						if (item.data === skuStr) {
							sku_id = item.id;
							return;
						}
					})
				}
				const list = {};
				const data = {};
				data.sku_id = sku_id;
				data.num = this.cartCount;
				if (this.productDetail.point_exchange_type == 2 || this.productDetail.point_exchange_type == 4) {
					list.type = 'point_exchange';
				} else {
					list.type = 'buy_now';
				}
				list.data = JSON.stringify(data);
				if(this.vipgd==0){
					uni.navigateTo({
						url: `/pages/order/create/order?data=${JSON.stringify(list)}`
					});
				}
				if(this.vipgd==1){
					uni.navigateTo({
						url: `/pages/order/create/order?data=${JSON.stringify(list)}&vip=1`
					});
				}
				
			},
			addCart(type) {
				if (!this.productDetail.id) return;
				this.specClass = 'show';
				this.cartType = type
			},
			stopPrevent() {}
		},
	}
</script>

<style scoped lang='scss'>
	page {
		background: $page-color-base;
		padding-bottom: 160upx;
	}

	.iconyou {
		font-size: $font-base + 2upx;
		color: #888;
	}

	.carousel {
		height: 722upx;
		position: relative;

		swiper {
			height: 100%;
		}

		.image-wrapper {
			width: 100%;
			height: 100%;
		}

		.swiper-item {
			display: flex;
			justify-content: center;
			align-content: center;
			height: 750upx;
			overflow: hidden;

			image {
				width: 100%;
				height: 100%;
			}
		}

	}

	/* 标题简介 */
	.introduce-section {
		background: #fff;
		padding: 20upx 30upx;

		.title {
			font-size: 32upx;
			color: $font-color-dark;
			height: 50upx;
			line-height: 50upx;
		}

		.sketch {
			display: block;
			color: $font-color-light;
			font-size: $font-base;
		}

		.price-box {
			display: flex;
			align-items: baseline;
			height: 64upx;
			padding: 10upx 0;
			font-size: 26upx;
			color: $base-color;
		}

		.point-box {
			color: $font-color-base;

			.price {
				color: $base-color;
				margin-left: 10upx;
			}
		}

		.price {
			font-size: $font-lg + 2upx;
		}

		.m-price {
			margin: 0 12upx;
			color: $font-color-light;
			text-decoration: line-through;
		}

		.coupon-tip {
			align-items: center;
			padding: 4upx 10upx;
			background: $uni-color-primary;
			font-size: $font-sm;
			color: #fff;
			border-radius: 6upx;
			line-height: 1;
			transform: translateY(-4upx);
		}

		.bot-row {
			display: flex;
			align-items: center;
			height: 50upx;
			font-size: $font-sm;
			color: $font-color-light;

			text {
				flex: 1;
			}
		}
	}

	/* 分享 */
	.share-section {
		display: flex;
		align-items: center;
		color: $font-color-base;
		background: linear-gradient(to left, #fdf5f6, #fbebf6);
		padding: 12upx 30upx;

		.share-icon {
			display: flex;
			align-items: center;
			width: 70upx;
			height: 30upx;
			line-height: 1;
			border: 1px solid $uni-color-primary;
			border-radius: 4upx;
			position: relative;
			overflow: hidden;
			font-size: 22upx;
			color: $uni-color-primary;

			&:after {
				content: '';
				width: 50upx;
				height: 50upx;
				border-radius: 50%;
				left: -20upx;
				top: -12upx;
				position: absolute;
				background: $uni-color-primary;
			}
		}

		.icon-xingxing {
			position: relative;
			z-index: 1;
			font-size: 24upx;
			margin-left: 2upx;
			margin-right: 10upx;
			color: #fff;
			line-height: 1;
		}

		.tit {
			font-size: $font-base;
			margin-left: 10upx;
		}

		.icon-bangzhu1 {
			padding: 10upx;
			font-size: 30upx;
			line-height: 1;
		}

		.share-btn {
			flex: 1;
			text-align: right;
			font-size: $font-sm;
			color: $uni-color-primary;
			background: none;
		}

		.share-btn:after {
			border: none;
		}

		.iconyou {
			font-size: $font-sm;
			margin-left: 4upx;
			color: $uni-color-primary;
		}
	}

	.company-logo {
		width: 100upx;
		height: 100upx;
		border-radius: 3px;
		margin-right: 9px;
	}

	.company-name {
		display: inline-block !important;
		color: #000;
		font-weight: 700;
		font-size: 30upx;
		position: absolute;
		left: 128upx;
		bottom: 4upx;
		overflow: hidden;
		text-overflow: ellipsis;
		white-space: nowrap;
		width: 78%;
	}

	.go-company {
		padding: 3px 12px;
		color: #fff;
		background: linear-gradient(90deg, #FF9800, #fe5c33);
		border-radius: 20px;
		position: absolute;
		right: 0;

	}

	.c-list {
		font-size: $font-sm + 2upx;
		color: $font-color-base;
		background: #fff;

		.c-row {
			display: flex;
			align-items: center;
			padding: 20upx 30upx;
			position: relative;
		}

		.tit {
			width: 140upx;
		}

		.con {
			flex: 1;
			color: $font-color-dark;

			.selected-text {
				margin-right: 10upx;
			}
		}

		.bz-list {
			height: 40upx;
			font-size: $font-sm+2upx;
			color: $font-color-dark;

			text {
				display: inline-block;
				margin-right: 30upx;
			}
		}

		.con-list {
			flex: 1;
			display: flex;
			flex-direction: column;
			color: $font-color-dark;
			line-height: 40upx;

			.buy-now {
				color: $uni-color-primary;
			}
		}

		.red {
			color: $uni-color-primary;
		}
	}

	/* 评价 */
	.eva-section {
		display: flex;
		flex-direction: column;
		padding: 28upx 30upx;
		background: #fff;
		margin-top: 16upx;

		.e-header {
			display: flex;
			align-items: center;
			height: 70upx;
			font-size: $font-sm + 2upx;
			color: $font-color-light;

			.tit {
				font-size: $font-base + 2upx;
				color: $font-color-dark;
				margin-right: 4upx;
			}

			.con {
				padding: 0;
			}

			.tip {
				flex: 1;
				text-align: right;
			}

			.iconyou {
				margin-left: 10upx;
			}
		}
	}

	.eva-box {
		display: flex;
		padding: 20upx 0;

		.portrait {
			flex-shrink: 0;
			width: 80upx;
			height: 80upx;
			border-radius: 100px;
		}

		.right {
			flex: 1;
			display: flex;
			flex-direction: column;
			font-size: $font-base;
			color: $font-color-base;
			padding-left: 26upx;

			.con {
				font-size: $font-base;
				color: $font-color-dark;
			}

			.bot {
				display: flex;
				justify-content: space-between;
				font-size: $font-sm;
				color: $font-color-light;
			}

			.name {
				align-items: center;
				display: flex;
				justify-content: space-between;
			}
		}
	}

	/*  详情 */
	.detail-desc {
		background: #fff;
		margin-top: 16upx;
		padding: 0 10upx;

		.d-header {
			display: flex;
			justify-content: center;
			align-items: center;
			height: 80upx;
			font-size: $font-base + 2upx;
			color: $font-color-dark;
			position: relative;

			text {
				padding: 0 20upx;
				background: #fff;
				position: relative;
				z-index: 1;
			}

			&:after {
				position: absolute;
				left: 50%;
				top: 50%;
				transform: translateX(-50%);
				width: 300upx;
				height: 0;
				content: '';
				border-bottom: 1px solid #ccc;
			}
		}
	}

	/* 规格选择弹窗 */
	.attr-content {
		padding: 10upx 30upx;

		.select-count {
			padding: 30upx 0 10upx;
			margin: 20upx 0;
			border-top: 1px solid #ccc;
			display: flex;
			justify-content: space-between;
			overflow: hidden;
			position: relative;
			font-size: $font-base + 6upx;
			color: $font-color-base;
			line-height: 60upx;

			.step {
				position: absolute;
				left: 60vw;
				bottom: 10upx;
			}
		}

		.a-t {
			display: flex;

			image {
				width: 170upx;
				height: 170upx;
				flex-shrink: 0;
				margin-top: -40upx;
				border-radius: 8upx;
				;
			}

			.right {
				display: flex;
				flex-direction: column;
				padding-left: 24upx;
				font-size: $font-sm + 2upx;
				color: $font-color-base;
				line-height: 42upx;

				.price {
					font-size: $font-lg;
					color: $uni-color-primary;
					margin-bottom: 10upx;
				}

				.selected-text {
					margin-right: 10upx;
				}
			}
		}

		.attr-list {
			display: flex;
			flex-direction: column;
			font-size: $font-base + 2upx;
			color: $font-color-base;
			padding-top: 15upx;
			padding-left: 10upx;
		}

		.item-list {
			padding: 10upx 0 0;
			display: flex;
			flex-wrap: wrap;

			.tit {
				display: flex;
				align-items: center;
				justify-content: center;
				background: #eee;
				margin-right: 20upx;
				margin-bottom: 20upx;
				border-radius: 100upx;
				min-width: 60upx;
				height: 60upx;
				padding: 0 20upx;
				font-size: $font-base;
				color: $font-color-dark;

				.img {
					width: 36upx;
					height: 24upx;
					margin: 0 4upx;
				}
			}

			.selected {
				background: #fbebee;
				color: $uni-color-primary;
			}
		}
	}

	/*  弹出层 */
	.popup {
		position: fixed;
		left: 0;
		top: 0;
		right: 0;
		bottom: 0;
		z-index: 99;

		&.show {
			display: block;

			.mask {
				animation: showPopup 0.2s linear both;
			}

			.layer {
				animation: showLayer 0.2s linear both;
			}
		}

		&.hide {
			.mask {
				animation: hidePopup 0.2s linear both;
			}

			.layer {
				animation: hideLayer 0.2s linear both;
			}
		}

		&.none {
			display: none;
		}

		.mask {
			position: fixed;
			top: 0;
			width: 100%;
			height: 100%;
			z-index: 1;
			background-color: rgba(0, 0, 0, 0.4);
		}

		.layer {
			position: fixed;
			z-index: 99;
			bottom: 0;
			width: 100%;
			border-radius: 10upx 10upx 0 0;
			background-color: #fff;

			.content {
				width: 100%;
				padding: 20upx 0;
			}

			.btn {
				height: 66upx;
				line-height: 66upx;
				border-radius: 100upx;
				background: $uni-color-primary;
				font-size: $font-base + 2upx;
				color: #fff;
				margin: 30upx 30upx 20upx;
			}
		}

		.layer-service {
			min-height: 600upx;

			.btn {
				width: calc(100% - 60upx);
				position: absolute;
				bottom: 0;
			}
		}

		&.service {
			min-height: 600upx;

			.row {
				margin: 30upx;

				.title {
					font-size: 30upx;
					margin: 10upx 0;
				}

				.description {
					font-size: 28upx;
					color: #999;
				}
			}
		}

		@keyframes showPopup {
			0% {
				opacity: 0;
			}

			100% {
				opacity: 1;
			}
		}

		@keyframes hidePopup {
			0% {
				opacity: 1;
			}

			100% {
				opacity: 0;
			}
		}

		@keyframes showLayer {
			0% {
				transform: translateY(120%);
			}

			100% {
				transform: translateY(0%);
			}
		}

		@keyframes hideLayer {
			0% {
				transform: translateY(0);
			}

			100% {
				transform: translateY(120%);
			}
		}
	}

	/* 底部操作菜单 */
	.page-bottom {
		position: fixed;
		left: 30upx;
		bottom: 30upx;
		z-index: 95;
		display: flex;
		justify-content: space-between;
		align-items: center;
		width: 690upx;
		height: 100upx;
		background: rgba(255, 255, 255, .9);
		box-shadow: 0 0 20upx 0 rgba(0, 0, 0, .5);
		border-radius: 16upx;

		.cart {
			position: relative;

			.badge {
				position: absolute;
				top: -8upx;
				right: 0upx;
			}
		}

		.p-b-btn {
			display: flex;
			flex-direction: column;
			align-items: center;
			justify-content: center;
			font-size: $font-sm;
			color: $font-color-base;
			width: 96upx;
			height: 80upx;

			.iconfont {
				font-size: 36upx;
				line-height: 48upx;
				color: $font-color-light;
			}

			&.active,
			&.active .iconfont {
				color: $uni-color-primary;
			}

			.icon-fenxiang2 {
				font-size: 42upx;
				transform: translateY(-2upx);
			}

			.iconshoucang {
				font-size: 40upx;
			}

			.icondanseshixintubiao- {
				font-size: 46upx;
			}

			.red {
				color: $base-color;
			}
		}

		.action-btn-group {
			display: flex;
			height: 76upx;
			border-radius: 100px;
			overflow: hidden;
			box-shadow: 0 20upx 40upx -16upx #fc9f56;
			box-shadow: 1px 2px 5px rgba(219, 63, 96, 0.4);
			background: linear-gradient(to right, #ffac30, #fc9f56, #F56C6C);
			margin: 0 20upx;
			position: relative;

			&:after {
				content: '';
				position: absolute;
				top: 50%;
				right: 50%;
				transform: translateY(-50%);
				height: 28upx;
				width: 0;
				border-right: 1px solid rgba(255, 255, 255, .5);
			}

			.action-btn {
				display: flex;
				align-items: center;
				justify-content: center;
				width: 180upx;
				height: 100%;
				font-size: $font-base;
				padding: 0;
				border-radius: 0;
				background: transparent;
			}
		}
	}

	/* 优惠券面板 */
	.mask {
		display: flex;
		align-items: flex-end;
		position: fixed;
		left: 0;
		top: var(--window-top);
		bottom: 0;
		width: 100%;
		background: rgba(0, 0, 0, 0);
		z-index: 9995;
		transition: .3s;

		.mask-content {
			width: 100%;
			min-height: 30vh;
			max-height: 70vh;
			background: #f3f3f3;
			transform: translateY(100%);
			transition: .3s;
			overflow-y: scroll;
		}

		&.none {
			display: none;
		}

		&.show {
			background: rgba(0, 0, 0, .4);

			.mask-content {
				transform: translateY(0);
			}
		}
	}

	/* 优惠券列表 */
	.coupon-item {
		display: flex;
		flex-direction: column;
		margin: 20upx 24upx;
		background: #fff;

		.con {
			display: flex;
			align-items: center;
			position: relative;
			height: 120upx;
			padding: 0 30upx;

			&:after {
				position: absolute;
				left: 0;
				bottom: 0;
				content: '';
				width: 100%;
				height: 0;
				border-bottom: 1px dashed #f3f3f3;
				transform: scaleY(50%);
			}
		}

		.left {
			display: flex;
			flex-direction: column;
			justify-content: center;
			flex: 1;
			overflow: hidden;
			height: 100upx;
		}

		.title {
			font-size: 32upx;
			color: $font-color-dark;
			margin-bottom: 10upx;
		}

		.time {
			font-size: 24upx;
			color: $font-color-light;
		}

		.right {
			display: flex;
			flex-direction: column;
			justify-content: center;
			align-items: center;
			font-size: 26upx;
			color: $font-color-base;
			height: 100upx;
		}

		.price {
			font-size: 44upx;
			color: $base-color;

			&:before {
				content: '￥';
				font-size: 34upx;
			}
		}

		.price-discount {
			font-size: 44upx;
			color: $base-color;
		}

		.tips {
			font-size: 24upx;
			color: $font-color-light;
			line-height: 60upx;
			padding-left: 30upx;
		}

		.circle {
			position: absolute;
			left: -6upx;
			bottom: -10upx;
			z-index: 10;
			width: 20upx;
			height: 20upx;
			background: #f3f3f3;
			border-radius: 100px;

			&.r {
				left: auto;
				right: -6upx;
			}
		}
	}

	.video-box {
		position: fixed;
		bottom: 200upx;
		right: 50rpx;
		height: 160rpx;
		width: 160rpx;
		z-index: 10;
	}

	.video-box>image {
		position: fixed;
		bottom: 200upx;
		right: 50rpx;

		height: 160rpx;
		width: 160rpx;
		border-radius: 4upx;
		z-index: 10;

	}

	.zhibo-bg {
		animation: spin 4s linear infinite 0s;
	}

	.zhibo-name {
		z-index: 11;
		animation: show-img 4s linear infinite 0s;
	}

	@-webkit-keyframes spin {
		0% {
			-webkit-transform: rotate(0deg);

		}

		50% {
			-webkit-transform: rotate(360deg);

		}

		100% {
			-webkit-transform: rotate(360deg);
		}
	}

	@keyframes spin {
		0% {
			transform: rotate(0deg);

		}

		50% {
			transform: rotate(360deg);

		}

		100% {
			transform: rotate(360deg);
		}

	}

	@-webkit-keyframes show-img {
		0% {
			opacity: 0;

		}

		50% {
			opacity: 1;

		}

		100% {
			opacity: 1;
		}
	}

	@keyframes show-img {
		0% {
			opacity: 0;

		}

		50% {
			opacity: 1;

		}

		100% {
			opacity: 1;
		}

	}

	.controls-title {
		z-index: 20;
		color: #fff;
		text-align: right;
		font-size: 28upx;
		float: right;
	}

	.uni-icon-clear:before {
		content: "\EA0F" !important;
	}

	.uni-icon-close-filled:before,
	.uni-icon-clear:before {
		content: '\EA0F';
	}

	.uni-video-bar {}

	/* .video-box /deep/ .uni-video-container>video {
	   position: fixed!important;
	}
	.video-box /deep/ .uni-video-bar {
	   position: fixed!important;
	}.video-box /deep/ .uni-video-container {
	   position: relative!important;
	} */
</style>
